// 给定两个没有重复元素的数组 nums1 和 nums2 ，其中nums1 是 nums2 的子集。找到 nums1 中每个元素在 nums2 中的下一个比其大的值。

// nums1 中数字 x 的下一个更大元素是指 x 在 nums2 中对应位置的右边的第一个比 x 大的元素。如果不存在，对应位置输出-1。

// 示例 1:

// 输入: nums1 = [4,1,2], nums2 = [1,3,4,2].
// 输出: [-1,3,-1]
// 解释:
//     对于num1中的数字4，你无法在第二个数组中找到下一个更大的数字，因此输出 -1。
//     对于num1中的数字1，第二个数组中数字1右边的下一个较大数字是 3。
//     对于num1中的数字2，第二个数组中没有下一个更大的数字，因此输出 -1。

// 示例 2:

// 输入: nums1 = [2,4], nums2 = [1,2,3,4].
// 输出: [3,-1]
// 解释:
//     对于num1中的数字2，第二个数组中的下一个较大数字是3。
//     对于num1中的数字4，第二个数组中没有下一个更大的数字，因此输出 -1。

// 注意:

//     nums1和nums2中所有元素是唯一的。
//     nums1和nums2 的数组大小都不超过1000。

var nextGreaterElement = function(nums1, nums2) {
    let map = new Map();
    for(let i = 0; i < nums2.length - 1; i++) {
    	let flag = false;
    	for(let j = i + 1; j < nums2.length; j++) {
    		if (nums2[i] < nums2[j]) {
				map.set(nums2[i], nums2[j]);
				flag = true
				break;
    		}
    	}
    	if (!flag) {
			map.set(nums2[i], -1);
    	}
    }
    map.set(nums2[nums2.length - 1], -1);
    let result = [];
    for(let i = 0; i < nums1.length; i++) {
    	result.push(map.get(nums1[i]));
    }
    return result;
};

console.log(nextGreaterElement([1,3,5,2,4], [6,5,4,3,2,1,7]));


